草庐IT

Java NIO 管道与阻塞队列

全部标签

ruby-on-rails - 了解为什么 ruby​​ 进程在 100% CPU 时阻塞的方法

我们有一个大型Rails应用程序,几天后,我们的ruby​​进程似乎陷入循环并占用100%的CPU,直到乘客服务器死机并引发502错误。您知道找出原因的最佳方法吗?我已经尝试过NewRelic,但它只是性能方面的东西,而且我们的错误太多了,无法猜测问题出在哪里。(我们每天有很多请求和很多UTF-8BSON错误,因为我们使用的是UTF-8url)使用:Rails3.2.6和Ruby1.9.2p290乘客3.0.13MongoDB2.0.1和Mongoid2.4.11NginxFreeBSD8.2 最佳答案 找出ruby卡住位置的简便方

ruby - 订阅一个队列,收到1条消息,然后取消订阅

我有一个场景,我需要极快地分发和处理作业。我将在队列中快速填充大约45个作业,我可以同时处理大约20个(5台机器,每台机器4个内核)。每项工作花费的时间长短不一,而且垃圾收集使事情变得复杂,因此我需要能够让消费者离线以进行垃圾收集。目前,我的一切都与pop一起工作(每个消费者每5毫秒弹出一次)。这似乎是不可取的,因为它转换为每秒600个pop请求到rabbitmq。如果有一个类似于订阅的pop命令,但只针对一条消息,我会很高兴。(进程会阻塞,等待来自rabbitMQ连接的输入,通过类似于Kernel.select的东西)我试图欺骗AMQPgem做这样的事情,但它不起作用:我似乎无法取消

ruby - Ruby 中百分号 + 管道运算符的含义是什么,如 "%|"?

我正在尝试理解thissite上呈现的脚本:#!/usr/bin/envrubyrequireENV['TM_SUPPORT_PATH']+'/lib/escape.rb'defterminal_script_filepath%|tellapplication"Terminal"activatedoscript"jsc-i#{e_as(e_sh(ENV['TM_FILEPATH']))}"endtell|endopen("|osascript","w"){|io|io最重要的是,函数terminal_script_filepath开头的部分:%|……|…以及它被“解析”的位置:{|io

ruby - 在 Ruby 中执行非阻塞 I/O 的首选方式是什么?

如果说我想检索一个网页进行解析,但在I/O发生时不阻塞CPU。是否有与Python的Eventlet库等效的东西? 最佳答案 Ruby的最佳HTTP客户端库是Typhoeus,它可用于以非阻塞方式并行执行多个HTTP请求。有阻塞和非阻塞接口(interface):#blockingresponse=Typhoeus::Request.get("http://stackoverflow.com/")putsresponse.body#non-blockingrequest1=Typhoeus::Request.new("http://

ruby-on-rails - 将 sidekiq 作业直接移至死队列

是否可以将sidekiq作业从SidekiqWorker实例级别直接移动到死队列(即在执行时)classMyWorkerincludeSidekiq::Workersidekiq_optionsretry:9defperform(name)ifname=='StackOverflow'#---->skip_retry_queue_and_go_to_dead_queueelse#do_stuff!endendend 最佳答案 在执行作业中不是动态的。静态地,如果您设置sidekiq_optionsretry:0,如果作业引发错误,它

ruby - 你如何将 shell 输出通过管道传递给 ruby​​ -e?

假设我在我的终端中输入了一些东西,比如:ls|grepphrase这样做之后我意识到我想删除所有这些文件。我想使用Ruby来这样做,但不太清楚要将什么传递给它。ls|grepphrase|ruby-e"whatdoIputinheretogothrougheachlinebyline?" 最佳答案 以此为起点:ls~|ruby-ne'print$_if$_[/^D/]'哪个返回:DesktopDocumentsDownloadsDropbox-n标志表示“遍历所有传入行”并将它们存储在“默认”变量$_中。我们没有看到该变量使用太多,

ruby-on-rails - 使用 Delayed::Job 管理多个作业队列

我想使用Delayed::Job(或者可能更适合我的问题的作业队列)将作业分派(dispatch)给多个后台守护进程。我有几个执行不同职责的后台守护进程。每个人都对Rails应用程序队列中的不同作业感兴趣。是否可以使用Delayed::Job,或者可能有更适合此任务的不同作业队列? 最佳答案 从那以后http://github.com/collectiveidea/delayed_job已达到v3.0并包括命名队列!非常适合简单的分组队列需求。 关于ruby-on-rails-使用Del

ruby-on-rails - ActiveJob 是否有具有特定优先级的队列?

查看下面的作业,我假设该作业在low_priority队列上运行。classGuestsCleanupJob我同意这一点,但这只是队列的名称对吗?它实际上与优先级无关。例如,如果我创建了一个队列名为:my_queue的作业,它将被视为具有与:low_priority队列相同的优先级。从文档中我无法找到任何表明我可以对排队的作业进行优先排序的信息。我知道delayed_jobs有这个功能,但我在active_job中没有找到它。 最佳答案 优先级取决于实际的QueueAdapter以及此适配器的配置方式。如果您的适配器不支持优先级或未

ruby - 如何将数据通过管道传输到通过标准输入上的 Net::SSH 启动的进程?

我正在本地机器上生成数据源,我想通过Net::SSH将其传输到远程进程。有点像echofoosball|sed's/foo/bar/g'只是echofoosball部分将是本地计算机上的数据馈送。我不要找的是:data="foosball"ssh.exec!("echo#{data}|sed's/foo/bar/g'")我真的想要实时将数据流传输到流程中;) 最佳答案 好吧,我明白了:#!/usr/bin/envrubyrequire'rubygems'require'net/ssh'res=""c=Net::SSH.start("

ruby - Errno::EPIPE:引发破损管道异常

if@blockrd,wr=IO.pipe@pid=forkdo$0="ForkedchildfromPage#{@path}"rd.closeresult=@block.call(@resp.body)beginwr.writeMarshal.dump(result)endwr.close这是与fork共享管道的非常标准的方法,但是一旦rd.close被调用,它就会断开管道供wr使用。直到那条线,管道才能正常工作(我用Pry逐行运行它)。据我所知,关闭fork内的读取器以阻止它干扰发送EOF是一种很好的做法(我不知道为什么会这样,我只知道这是做法)。这是我调用到生产应用程序中的库的一